<template>
  <el-drawer v-model="visibleInternalDesc" size="60%" :append-to-body="true">
    <template #header>
      <div class="flex align-center" style="margin-left: -8px">
        <el-button class="cursor mr-4" link @click.prevent="visibleInternalDesc = false">
          <el-icon :size="20">
            <Back />
          </el-icon>
        </el-button>
        <h4>详情</h4>
      </div>
    </template>

    <div>
      <div class="card-header">
        <div class="flex-between">
          <div class="title flex align-center">
            <el-avatar
              v-if="isAppIcon(toolDetail?.icon)"
              shape="square"
              :size="64"
              style="background: none"
              class="mr-8"
            >
              <img :src="toolDetail?.icon" alt="" />
            </el-avatar>
            <el-avatar
              v-else-if="toolDetail?.name"
              :name="toolDetail?.name"
              pinyinColor
              shape="square"
              :size="64"
              class="mr-8"
            />
            <div class="ml-16">
              <h3 class="mb-8">{{ toolDetail.name }}</h3>
              <el-text type="info" v-if="toolDetail?.desc">
                {{ toolDetail.desc }}
              </el-text>
            </div>
          </div>
        </div>

        <div class="mt-16" v-if="toolDetail?.downloads != undefined">
          <el-text type="info">
            <div>
              {{ $t('views.document.upload.download') }}:
              {{ numberFormat(toolDetail?.downloads || 0) }}
            </div>
          </el-text>
        </div>
      </div>
      <MdPreview
        ref="editorRef"
        editorId="preview-only"
        :modelValue="markdownContent"
        style="background: none"
        noImgZoomIn
      />
    </div>
  </el-drawer>
</template>

<script setup lang="ts">
import { ref, watch } from 'vue'
import { cloneDeep } from 'lodash'
import { isAppIcon, numberFormat } from '@/utils/common'
const emit = defineEmits(['refresh', 'addTool'])

const visibleInternalDesc = ref(false)
const markdownContent = ref('')
const toolDetail = ref<any>({})

watch(visibleInternalDesc, (bool) => {
  if (!bool) {
    markdownContent.value = ''
  }
})

const open = (data: any, detail: any) => {
  toolDetail.value = detail
  if (data) {
    markdownContent.value = cloneDeep(data)
  }
  visibleInternalDesc.value = true
}

defineExpose({
  open,
})
</script>
<style lang="scss"></style>
